package com.baby.listener;

import com.rabbitmq.client.Channel;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener;

import java.io.IOException;

public class SimpleAskConsumerListener implements ChannelAwareMessageListener {


    @Override
    public void onMessage(Message message, Channel channel) throws Exception {
        Thread.sleep(5000);
        // 获取消息传递标记
        long deliveryTag = message.getMessageProperties().getDeliveryTag();
        try {
        // ① 接收消息
            System.out.println(new String(message.getBody()));
        // ② 处理业务逻辑
            System.out.println("处理业务逻辑");
//            int i = 3 / 0;//出现错误
        // ③ 手动签收
        /**
         * 第一个参数：表示收到的标签
         * 第二个参数：如果为true表示可以签收所有的消息
         */
            channel.basicAck(deliveryTag, false);
        } catch (Exception e) {
            e.printStackTrace();
        // ④ 拒绝签收
        /*
        第一，第二参数同basicAck
        第三个参数：requeue：重回队列。
        设置为true,则消息重新回到queue,broker会重新发送该消息给消费端
        */
            channel.basicNack(deliveryTag, false, true);
        }
    }
}
